from info.constants import CLICK_RANK_MAX_NEWS, HOME_PAGE_MAX_NEWS
from info.models import User, News, Category
from info.modules.home import home_blu
from flask import render_template, current_app, session, request, jsonify

import logging # python 内置的日志模块，可以在控制台中显示，刻可以将日志写入到日志文件中
#  共四部－－第三部使用蓝图装饰视图
from info.utils.response_code import RET, error_map

# 新闻首页，排行列表
# 技术选型：新闻排行跟随首页显示（全局刷新），并且新闻排行余姚SEO:所以后端渲染
@home_blu.route('/')
def index():
    # 判断用户是否登录
    user_id = session.get('user_id')
    user = None
    if user_id:
        try:
            # 根据user_id 查询用户模型
            user = User.query.get(user_id)

        except BaseException as e :
            current_app.logger.error(e)
    # 将用户登录的信息传递到模板中，全局刷新，我们采取后端渲染
    user = user.to_dict() if user else None

    # 查询新闻，按照点击量的倒序排列取前面１０条
    rank_list = []
    try:
        rank_list = News.query.order_by(News.clicks.desc()).limit(CLICK_RANK_MAX_NEWS).all()

    except BaseException as e :
        current_app.logger.error(e)

    rank_list = [news.to_basic_dict() for  news in rank_list]

    categories = []
    # 查询所有的分类
    try:
        categories = Category.query.all()
    except BaseException as e :
        current_app.logger.error(e)  # 这里接下来模板渲染

    return render_template('news/index.html', user=user, rank_list = rank_list, categories=categories)



# 获取浏览器上面的小图标，浏览器发出的请求
@home_blu.route('/favicon.ico')
def favicon():
    return current_app.send_static_file('news/favicon.ico')

# 获取分类列表
@home_blu.route('/get_news_list')
def get_news_list():
    # 获取参数
    cid = request.args.get('cid')
    cur_page = request.args.get('cur_page')
    per_count = request.args.get('per_count',HOME_PAGE_MAX_NEWS)

    # 校验参数
    if not all([cid,cur_page]):
        return jsonify(errno=RET.PARAMERR,errmsg=error_map[RET.PARAMERR])


    # 将参数转化为整型
    try:
        cid = int(cid)
        per_count = int(per_count)
        cur_page = int(cur_page)
    except BaseException as e :
        current_app.logger.error(e)
        return jsonify(errno=RET.PARAMERR,errmsg=error_map[RET.PARAMERR])

    filter_list = []
    if cid != 1:
        filter_list.append(News.category_id==cid)
    # 根据参数查询新闻数据，按照分类进行分页查询（生成日期倒序）
    try:
        pn = News.query.filter(*filter_list).order_by(News.create_time.desc()).paginate(cur_page,per_count)

    except BaseException as e :
        current_app.logger.error(e)
        return jsonify(errno=RET.DBERR,errmsg=error_map[RET.DBERR])

    data = {
        'news_list' :[news.to_dict() for news in pn.items],
        'total_page' : pn.pages  # 总页数
    }

    # 将数据以　json 返回
    return jsonify(errno=RET.OK, errmsg=error_map[RET.OK],data = data)
